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IN THE CLAIMS 

This listing of claims will replace all prior versions and listings of claims in the 
Application: 

LISTING OF CLAIMS: 

1 . (Original) A method of blocking attacks on a protected computer network, 
comprising: 

receiving a plurality of packets from a network, each said packet having a 
packet time to live (TTL) value and belonging to a corresponding 
packet flow; 

storing the smallest packet TTL value received from each said 

corresponding packet flow; and 
prior to transmitting each said packet, setting said packet TTL value to 

said smallest packet TTL value received for said corresponding packet 

flow. 

2. (Currently Amended) The method of Claim 1 , wherein said storing the 
smallest packet TTL value comprises: 

associating and-an epoch with said stored smallest packet TTL value; and 
if said epoch is greater than a predefined value, discarding said stored 
smallest packet TTL value. 

3. (Original) The method of Claim 1 , further comprising periodically resetting 
said stored smallest packet TTL value to a maximum value. 

4. (Original) The method of Claim 1 , wherein said setting said packet TTL value 
comprises: 

determining if said corresponding packet flow is on an unrestricted list; 
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and if said corresponding packet flow is on said unrestricted list, setting 
said packet TTL value to a maximum value. 

5. (Original) The method of Claim 1 , wherein said setting said packet TTL value 
comprises: 

determining if said corresponding packet flow is on an unrestricted list; 
and if said corresponding packet flow is on said unrestricted list, leaving 
said packet TTL value unchanged. 

6. (Original) An apparatus for blocking attacks on a protected computer network, 
comprising: 

means for receiving a plurality of packets from a network, each said 

packet having a packet time to live (TTL) value and belonging to a 

corresponding packet flow; 
means for storing the smallest packet TTL value received from each said 

corresponding packet flow; and 
means for setting said packet TTL value to said smallest packet TTL value 

received for said corresponding packet flow prior to transmitting each 

said packet. 

7. (Currently Amended) The apparatus of Claim 6, wherein said means for 
storing the smallest packet TTL value comprises: 

means for associating and-an epoch with said stored smallest packet TTL 
value; and 

means for discarding said stored smallest packet TTL value if said epoch 
is greater than a predefined value. 

8. (Original) The apparatus of Claim 6, further comprising means for periodically 
resetting said stored smallest packet TTL value to a maximum value. 
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9. (Original) The apparatus of Claim 6, wherein said means for setting said 
packet TTL value comprises: 

means for determining if said corresponding packet flow is on an 

unrestricted list; and 
means for setting said packet TTL value to a maximum value if said 

corresponding packet flow is on said unrestricted list. 

1 0. (Original) The apparatus of Claim 6, wherein said means for setting said 
packet TTL value comprises: 

means for determining if said corresponding packet flow is on an 

unrestricted list; and 
means for leaving said packet TTL value unchanged if said corresponding 

packet flow is on said unrestricted list. 

1 1 . (Original) An apparatus for blocking attacks on a protected computer network, 
comprising: 

a packet classifier configured to receive a plurality of packets from a 

network, each said packet having a packet time to live (TTL) value and 

belonging to a corresponding packet flow; 
a memory configured to store the smallest packet TTL value received from 

each said corresponding packet flow; and 
a TTL rewrite unit configured to set said packet TTL value to said smallest 

packet TTL value received for said corresponding packet flow prior to 

transmitting each said packet. 

12. (Currently Amended) The apparatus of Claim 1 1 , wherein said memory 
comprises: 

first control means for associating afld-an epoch with said stored smallest 
packet TTL value; and 
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second control means for discarding said stored smallest packet TTL 
value if said epoch is greater than a predefined value. 

1 3. (Original) The apparatus of Claim 1 1 , further comprising control means for 
periodically resetting said stored smallest packet TTL value to a maximum value. 

14. (Original) The apparatus of Claim 11, wherein said TTL rewrite unit 
comprises: 

first control means for determining if said corresponding packet flow is on 

an unrestricted list; and 
second control means for setting said packet TTL value to a maximum 

value if said corresponding packet flow is on said unrestricted list. 

15. (Original) The apparatus of Claim 11, wherein said TTL rewrite unit 
comprises: 

first control means for determining if said corresponding packet flow is on 

an unrestricted list; and 
second control means for leaving said packet TTL value unchanged if said 

corresponding packet flow is on said unrestricted list. 

Claims 16-20 (Canceled). 

21 . (Currently Amended) A computer program product comprising a computer- 
readable medium having instructions stored thereon that, when performed by a 
computer, cause the stor i ng a compute r program executab l e by a p l ura li ty of 
s e rv e r comput e rs, th e comput e r program compr i s i ng comput e r i nstruct i ons for to 
perform the following operations : 

receiving a plurality of packets from a network, each said packet having a 

packet time to live (TTL) value and belonging to a corresponding 

packet flow; 
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storing the smallest packet TTL value received from each said 

corresponding packet flow; and 
prior to transmitting each said packet, setting said packet TTL value to 

said smallest packet TTL value received for said corresponding packet 

flow. 

22. (Currently Amended) The compute r r e adab le program product m e d i um of 
Claim 21 , wherein said comput e r instructions for storing the smallest packet TTL 
value comprise comput e r instructions that, when performed by the computer, 
cause the computer to perform the following operations- fef: 

associating aftd-an epoch with said stored smallest packet TTL value; and 
if said epoch is greater than a predefined value, discarding said stored 
smallest packet TTL value. 

23. (Currently Amended) The compute r r e adab le m e d i um program product of 
Claim 21 , further comprising comput e r instructions that, when performed by the 
computer, further cause the computer to perform the following f or- operations: 

periodically resetting said stored smallest packet TTL value to a maximum 
value. 

24. (Currently Amended) The compute r r e adab le m e d i um program product of 
Claim 21 , wherein said comput e r instructions for setting said packet TTL value 
comprise comput e r instructions4o f that, when performed by the computer, cause 
the computer to perform the following operations : 

determining if said corresponding packet flow is on an unrestricted list; 
and 

if said corresponding packet flow is on said unrestricted list, setting said 
packet TTL value to a maximum value. 
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25. (Currently Amended) The compute r roodob l o mod i um program product of 
Claim 21 , wherein said computer instructions for setting said packet TTL value 
comprise comput e r instructions ^ that, when performed by the computer, cause 
the computer to perform the following operations : 

determining if said corresponding packet flow is on an unrestricted list; 
and 

if said corresponding packet flow is on said unrestricted list, leaving said 
packet TTL value unchanged. 

Claims 26-30 (Canceled). 

31 . (New) The method of Claim 1 , wherein storing the smallest packet TTL 
value received from each said corresponding packet flow includes, for each said 
packet: 

if that packet is the first packet received from said corresponding packet 
flow, then storing the packet TTL value of that packet as said smallest 
packet TTL value received from said corresponding packet flow; 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is less than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then storing the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding packet 
flow; and 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is greater than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then refraining from storing the packet TTL value of that 
packet as said smallest packet TTL value received from said 
corresponding packet flow. 
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32. (New) The method of Claim 1 , wherein storing the smallest packet TTL 
value received from each said corresponding packet flow includes, for each said 
packet: 

if that packet is the first packet received from said corresponding packet 
flow, then: 

storing the packet TTL value of that packet as said smallest packet 
TTL value received from said corresponding packet flow; and 

associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise, if the packet TTL value of that packet is less than or equal to 
the stored smallest packet TTL value received from said corresponding 
packet flow, then: 

storing the packet TTL value of that packet as said smallest packet 

TTL value received from said corresponding packet flow; and 
associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise, if an amount of time elapsed since the time indicated by the 
timestamp is greater than a predefined value, then: 

storing the packet TTL value of that packet as said smallest packet 

TTL value received from said corresponding packet flow; and 
associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise: 
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refraining from storing the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

refraining from associating a new timestamp with said stored 
smallest packet TTL value. 

33. (New) The apparatus of Claim 6, wherein said means for storing the 
smallest packet TTL value received from each said corresponding packet flow 
includes means for, for each said packet: 

if that packet is the first packet received from said corresponding packet 
flow, then storing the packet TTL value of that packet as said smallest 
packet TTL value received from said corresponding packet flow; 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is less than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then storing the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding packet 
flow; and 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is greater than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then refraining from storing the packet TTL value of that 
packet as said smallest packet TTL value received from said 
corresponding packet flow. 

34. (New) The apparatus of Claim 6, wherein said means for storing the 
smallest packet TTL value received from each said corresponding packet flow 
includes means for, for each said packet: 

if that packet is the first packet received from said corresponding packet 
flow, then: 
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storing the packet TTL value of that packet as said smallest packet 
TTL value received from said corresponding packet flow; and 

associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise, if the packet TTL value of that packet is less than or equal to 
the stored smallest packet TTL value received from said corresponding 
packet flow, then: 

storing the packet TTL value of that packet as said smallest packet 

TTL value received from said corresponding packet flow; and 
associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise, if an amount of time elapsed since the time indicated by the 
timestamp is greater than a predefined value, then: 

storing the packet TTL value of that packet as said smallest packet 

TTL value received from said corresponding packet flow; and 
associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise: 

refraining from storing the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

refraining from associating a new timestamp with said stored 
smallest packet TTL value. 
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ss. (New) The apparatus of Claim 1 1 , further comprising a controller, the 

controller being configured to, for each said packet: 

if that packet is the first packet received from said corresponding packet 
flow, then store in memory the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding packet 
flow; 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is less than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then store in memory the packet TTL value of that packet 
as said smallest packet TTL value received from said corresponding 
packet flow; and 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is greater than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then refrain from storing in memory the packet TTL value 
of that packet as said smallest packet TTL value received from said 
corresponding packet flow. 

36. (New) The apparatus of Claim 1 1 , further comprising a controller, the 
controller being configured to, for each said packet: 

if that packet is the first packet received from said corresponding packet 
flow, then: 

store in memory the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

associate a timestamp with said stored smallest packet TTL value, 
the timestamp indicating the time at which said smallest packet 
TTL value received from said corresponding packet flow was 
stored; 
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otherwise, if the packet TTL value of that packet is less than or equal to 
the stored smallest packet TTL value received from said corresponding 
packet flow, then: 

store in memory the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

associate a timestamp with said stored smallest packet TTL value, 
the timestamp indicating the time at which said smallest packet 
TTL value received from said corresponding packet flow was 
stored; 

otherwise, if an amount of time elapsed since the time indicated by the 
timestamp is greater than a predefined value, then: 

store in memory the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

associate a timestamp with said stored smallest packet TTL value, 
the timestamp indicating the time at which said smallest packet 
TTL value received from said corresponding packet flow was 
stored; 
otherwise, refrain from: 

storing in memory the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

associating a new timestamp with said stored smallest packet TTL 
value. 



37. (New) The computer program product of Claim 21 , wherein said 
instructions for storing the smallest packet TTL value received from each said 
corresponding packet flow comprise instructions that, when performed by the 
computer, cause the computer to perform the following operations: 
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if that packet is the first packet received from said corresponding packet 
flow, then storing the packet TTL value of that packet as said smallest 
packet TTL value received from said corresponding packet flow; 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is less than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then storing the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding packet 
flow; and 

if that packet is not the first packet received from said corresponding 
packet flow and the packet TTL value of that packet is greater than the 
stored smallest packet TTL value received from said corresponding 
packet flow, then refraining from storing the packet TTL value of that 
packet as said smallest packet TTL value received from said 
corresponding packet flow. 

38. (New) The computer program product of Claim 21 , wherein said 
instructions for storing the smallest packet TTL value received from each said 
corresponding packet flow comprise instructions that, when performed by the 
computer, cause the computer to perform the following operations: 

if that packet is the first packet received from said corresponding packet 
flow, then: 

storing the packet TTL value of that packet as said smallest packet 
TTL value received from said corresponding packet flow; and 

associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 
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otherwise, if the packet TTL value of that packet is less than or equal to 
the stored smallest packet TTL value received from said corresponding 
packet flow, then: 

storing the packet TTL value of that packet as said smallest packet 

TTL value received from said corresponding packet flow; and 
associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise, if an amount of time elapsed since the time indicated by the 
timestamp is greater than a predefined value, then: 

storing the packet TTL value of that packet as said smallest packet 

TTL value received from said corresponding packet flow; and 
associating a timestamp with said stored smallest packet TTL 
value, the timestamp indicating the time at which said smallest 
packet TTL value received from said corresponding packet flow 
was stored; 

otherwise: 

refraining from storing the packet TTL value of that packet as said 
smallest packet TTL value received from said corresponding 
packet flow; and 

refraining from associating a new timestamp with said stored 
smallest packet TTL value. 



